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Method And Apparatus for Determining A Layer 2 Path In A Switched 

Network 

FIELD OF INVENTION 

The present invention generally relates to management of computer networks, and 
5 relates more specifically to determining a Layer 2 path between two or more nodes in a 
switched network. 

BACKGROUND OF THE INVENTION 

A computer network generally includes a number of devices, including switches, 
routers and hubs, connected so as to allow communication among the devices. The 

10 devices within a network are often categorized into two classes: end stations such as 
workstations, desktop PCs, printers, servers, hosts, fax machines, and devices that 
primarily supply or consume information; and network devices such as gateways, 
switches and routers that primarily forward information between the other devices. 

Network devices ordinarily operate on a continuous basis. Each device has one or 

1 5 more circuit boards, a microprocessor and a memory, and runs a control program. In 
general, networks often include several different types of data switching and routing 
devices. These network devices may have different physical characteristics. New devices, 
with characteristics that are presently unknown, are constantly being developed, hi 
addition, the characteristics of many network devices may change over time. For 

20 example, characteristics of the network devices change when subsystems like boards, 
network interface modules, and other parts are added or removed from a device. 
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Many networks are managed, supervised and maintained by a network 
administrator or network manager. To properly maintain a network, the network 
administrator needs to have up-to-date information available about the devices in the 
network, how the devices are interconnected, and how data packets move among devices 
5 along logical and physical paths. The Open Systems hiterconnection ("OSI") network 
reference model is useful in classifying logical communication layers of network devices 
that can be used to collect network management information. Layer 2 and Layer 3 refer 
to the data link layer and the network layer respectively in the OSI model. 

Layer 2 comiectivity information may be used by the network administrator to 
1 0 determine and understand the physical topology of the network. The topology is a 

representation of the type of devices that are currently included in the network and how 
the interfaces of these devices are physically hnked. Layer 3 information describes 
logical connectivity between a source and a destination device as specified by 
intermediary Layer 3 routing devices. 
1 5 An effective network management system would create a topology based on both 

the logical connections of network devices, and the physical connection information. Not 
only would the network management system be capable of logically identifying to which 
network a particular device is linked, based on Layer 3 information, it would also indicate 
how individual devices are physically linked together, based on Layer 2 information. 
20 Thus, an administrator could determine the actual interface links or physical connectivity 
of each of the devices. This information maybe critical in determining how the network 
can be expanded or upgraded, or in troubleshooting. 
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Certain proprietary discovery protocols have been developed to help identify how 
the interfaces of each device are physically linked within a network, based on Layer 2 
information. For example, the Cisco Discovery Protocol ("CDP"), which is used in 
products that are commercially available from Cisco Systems, Inc., San Jose, California, 
is a low-level communication protocol that can help a network management system 
identify how devices are linked in a network. When a device supporting CDP sends a 
message to another device, the message includes a packet that contains its IP address and 
an interface descriptor. The interface descriptor represents the logical name of the port 
from which the message was sent. The information is stored at the receiving device and 
may be used to determine how two devices are physically connected. 

However, knowledge of the physical topology of the network may not be 
sufficient for diagnosing an error in the network. To diagnose certain error, logical path 
information is needed. One technique of gathering information on errors and 
configuration in a network that uses hitemet Protocol ("IP") is path tracing for an IP 
packet. Path information defines the traversal of a packet or a sequence of packets from a 
source device to a destination device, whereas topology information defines either the 
physical or logical layout of a network without taking into account factors that affect the 
path fraversed by a packet. The factors that affect the path fraversed by a packet include 
spanning tree blocking, route determination, network misconfiguration, access-list 
prohibition, cable cuts, etc. 

FIG. 1 A is a block diagram of a network that illusfrates the difference between 
path and topology. Access Switches 102a, 104a is each connected to users 102b, 104b 
respectively. Core Switch 110 is connected to Backbone 112. Core Switch 110 is 
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connected to Access Switch 102a and Access Switch 104a by intermediary devices such 

as Distribution Switch 106 and Root Bridge 108. 

Access Switch 102a is connected to Distribution Switch 106 by Connection 118 

through Access Ports 1 18a, 1 18b. Similarly, Access Switch 102a is connected to Root 
5 Bridge 108 by Connection 1 14 and through Access Ports 1 14a, 1 14b. 

Access Switch 104a is connected to Distribution Switch 106 by Connection 116 

through Access Ports 1 16a, 1 16b. Also, Access Switch 104a is connected to Root Bridge 

108 by Connection 120 and through Access Ports 120a, 120b. Core Switch 1 10 is 

connected to Distribution Switch 106 by Connection 122 and Access Ports 122a, 122b. 
1 0 Core Switch 1 1 0 is also connected to Root Bridge 1 08 by Connection 1 24 and Access 

Ports 124a, 124b. 

The layout of the network as depicted by the connections between the devices in 
FIG. 1 A is referred to as the topology of the network. In contrast, the path that a packet 
would traverse from a source device to a destination device would vary depending on the 

1 5 Spanning Tree information for the network. 

The Spanning Tree protocol, defined in IEEE Specification 802. ID, is a method 
used to determine a "loop-free" subset of a network topology, hi the context of Spanning 
Tree, a "loop" is a path on which packets never reach their destination, but cycle 
repeatedly through a series of devices that comprise the loop. FIG IB is a block diagram 

20 that illustrates a loop in a network. A packet that may be originating from Access Switch 
102a and destined for Access Switch 104a would never reach Access Switch 104a by 
tiaversing the loop path comprising Connections 118, 122, 124, 1 14. 
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By applying the Spanning Tree algorithm to a given network topology, loop paths 
are prevented by determining which access ports in the topology should be placed in a 
"blocked state" in order to create a loop-free Spanning Tree for the given network. For 
example, referring to FIG. 1 A, Access Ports 1 14a, 1 14b, 1 16a, 1 16b can be placed in a 
blocked state as a result of applying a Spanning Tree algorithm to the network of FIG. 
1 A. Because Access Ports 1 14a, 1 14b, 1 16a, 1 16b are in the blocked state, a loop-free 
Spanning Tree is achieved, comprising Connections 118, 122, 124, 120, and Connections 
114, 1 16 are shown as dotted Unes to indicate that they are not part of the Spanning Tree. 
Thus, for the purposes of illustration, the solid lines as shown in FIG. IC indicate the 
Spanning Tree. 

For most accurate path tracing, it is desirable for IP path tracing to be performed 
both at Layer 3 and Layer 2. A Layer 2 IP path is also referred to as a "data link path". A 
data link path is important for network monitoring and diagnostics because the 
information obtained from IP path teacing performed at Layer 3 may be insufficient. For 
example, IP path tracing at Layer 3 identifies a path from router to router and does not 
identify the actual network devices such as LANs switches and bridges that an IP packet 
may traverse to get from a source device to a destination device. Thus, the path between 
any two Layer 3 devices may traverse entire networks of devices that operate at Layer 2. 

Tools such as the UNIX-based traceroute computer program and the Windows- 
based tracert computer program are used to perform IP path tracing at Layer 3 . However, 
techniques for direct IP tracing at Layer 2 that are suitable for a wide range of 
technologies including Ethernet, Local Area Network Emulation, Token Ring, and 
EtherChannel are not available. 
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Based on the foregoing, there is a clear need for a method that can identify the 
data Hnk path from a source device to a destination device on the network. 

There is a specific need for a way to carry out IP Path tracing at OSI Layer 2 for 
use in network management functions. 
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SUMMARY OF THE INVENTION 

The foregoing needs, and other needs and objects that will become apparent for 
the following description, are achieved in the present invention, which comprises, in one 
aspect, a method of determining a Layer 2 path between a source device and a destination 
device in a switched network, the method comprising the computer-implemented steps of: 
determining a Layer 3 path between the source device and the destination device, wherein 
the Layer 3 path comprises information identifying two or more Layer 3 devices; 
determining a subpath for each contiguous pair of Layer 3 devices in the Layer 3 path; 
and concatenating the subpaths to result in creating and storing information representing 
the Layer 2 path. 

One feature of this aspect is that determining a subpath for each contiguous pair of 
Layer 3 devices comprises the steps of: determining a first interface on a first node of the 
contiguous pair that is connected to a second interface on a second node of the contiguous 
pair for a given subnet; and selecting a relevant VLAN between the first and second nodes 
of the contiguous pair based on the first and second interfaces; and gathering current 
spanning tree information for the relevant VLAN. 

According to another feature of this aspect is that selecting a relevant VLAN 
between the first and second nodes of the contiguous pair comprises the steps of: selecting 
a matching native VLAN of the first and second node of the contiguous pair as the 
relevant VLAN when the first interface and the second interface of the first and second 
nodes respectively of the contiguous pair are non-VLAN trunking interfaces; selecting a 
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matching active VLAN that is designated to carry traffic to a next hop as the relevant 
VLAN when the first interface and the second interface of the first and second nodes 
respectively of the contiguous pair are VLAN trunking interfaces; and selecting a native 
VLAN that is on a non-VLAN trunking interface as the relevant VLAN when one of the 

5 nodes of the contiguous pair has the non-VLAN trunking interface. 

According to another feature, determining a subpath for each contiguous pair of 
Layer 3 devices fiirther comprises the steps of: tracing a first path segment fi:om a first 
node of the contiguous pair by following a spanning tree associated with a relevant VLAN 
for the contiguous pair to a root of the spanning tree; tracing a second path segment fi-om 

1 0 a second node of the contiguous pair by following the spanning tree associated with the 
relevant VLAN for the contiguous pair to the root of the spanning tree; and concatenating 
the first second path segments to result in creating and storing the subpath for the 
contiguous pair. 

In another feature, concatenating the first path segment and the second path 
1 5 segment to result in creating and storing the subpath for the contiguous pair includes the 
step of eliminating extraneous devices fi-om the first and second path segments. 

In another feature, concatenating the subpaths to result in creating and storing 
information representmg the Layer 2 path includes the step of eliminating exti-aneous 
devices from the subpaths. 
20 According to another aspect of determining a Layer 2 path between a source 

device and a destination device in a switched network, the method comprises the 
computer-implemented steps of: determining a Layer 3 path between the source device 
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and the destination device, wherein the Layer 3 path comprises information identifying 
two or more Layer 3 devices; identifying contiguous pairs of Layer 3 devices in the Layer 
3 path; determining a subpath for each contiguous pair of Layer 3 devices in the Layer 3 
path; determining whether any contiguous pair of Layer 3 devices has no subpath; 
5 concluding that there is no Layer 2 path when any contiguous pair of Layer 3 devices has 
no subpath; eUminating extraneous devices in the subpaths; and concatenating the 
subpaths to result in creating and storing information representing the Layer 2 path when 
each of the contiguous pairs of Layer 3 devices has a subpath. 

According to one feature of this aspect is that determining a subpath for each 
1 0 contiguous pair of Layer 3 devices comprises the steps of: determining a first interface on 
a first node of the contiguous pair that is connected to a second interface on a second node 
of the contiguous pair for a given subnet when both the first node of the contiguous pair 
and the second node of the contiguous pair have non-trunking interfaces; determining a 
first native VLAN of the first interface and a second native VLAN the second interface; 
1 5 determining whether the first native VLAN matches the second native VLAN; selecting 
the matching VLAN as a relevant VLAN between the first and second nodes of the 
contiguous pair when the first native VLAN matches the second native VLAN; gathering 
a current spanning tree information for the relevant VLAN; tracing a first path segment 
from the first node of the contiguous pair to a root of the spanning tree by following the 
20 current spanning tree information associated with the relevant VLAN to a root of the 

spanning ti-ee; ti-acing a second path segment from the second node of the contiguous pair 
to the root of the spanning tree by following the current spanning free information 
associated with the relevant VLAN; eliminating exti-aneous devices in the first and second 
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path segments; and concatenating the first path segment and the second path segment to 
result in creating and storing the subpath for the contiguous pair. 

In another feature, determining a subpath for each contiguous pair of Layer 3 
devices comprises the steps of: determining a non-trunking node of the contiguous pair 

5 when one of the nodes of the contiguous pair for a given subnet has a non- trunking 
interface and the other node of the contiguous pair has a trunking interface; determining 
the non-trunking interface on the non-trunking node of the contiguous pair as a first 
interface that is connected to a second interface on the other node of the contiguous pair; 
determining a native VLAN on the first interface; determining whether there is an active 

1 0 VLAN on the second interface that matches the native VLAN on the first interface; 

selecting the matching VLAN as a relevant VLAN between the non-trunking node and the 
other node of the contiguous pair when there is an active VLAN on the second interface 
that matches the native VLAN on the first interface; gathering a current spanning tree 
information for the relevant VLAN; tracing a first path segment firom the non-trunking 

1 5 node of the contiguous pair to a root of tiie spanning tree by following the current 

spanning tree information associated with the relevant VLAN to a root of the spanning 
tree; tracing a second path segment fi-om the other node of the contiguous pair to the root 
of the spanning tree by following the current spanning tree information associated with 
the relevant VLAN; eliminating extraneous devices in the first and second path segments; 

20 and concatenating the first path segment and the second path segment to result in creating 
and storing the subpath for the contiguous pair. 

In another feature, determining a subpath for each contiguous pair of Layer 3 
devices comprises the steps of: determining a first interface on a first node of the 
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contiguous pair that is connected to a second interface on a second node of the contiguous 
pair for a given subnet when both the first node of the contiguous pair and the second 
node of the contiguous pair have non-trunking interfaces; and determining a first active 
VLAN of the first interface associated with the given subnet and a second active VLAN 

5 the second interface associated with the given subnet; determining whether the first active 
VLAN matches the second active VLAN; selecting the matching VLAN as a relevant 
VLAN between the first and second nodes of the contiguous pair when the first active 
VLAN matches the second active VLAN; gatiiering a current spanning tree information 
for the relevant VLAN; tracing a first path segment fi-om the first node of the contiguous 

1 0 pair to a root of the spanning tree by following tiie current spanning tree information 
associated with the relevant VLAN to a root of the spanning tree; tracing a second path 
segment from the second node of the contiguous pair to the root of the spanning tree by 
following the current spanning tree information associated with the relevant VLAN; 
eliminating extraneous devices in the first and second path segments; and concatenating 

1 5 the first path segment and the second path segment to result in creating and storing the 
subpath for the contiguous pair. 

hi other aspects, the invention encompasses a computer apparatus, a computer 
readable medium, and a carrier wave configured to carry out the foregoing steps. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention is illustrated by way of example, and not by way of 
limitation, in the figures of the accompanying drawings and in which like reference 
numerals refer to similar elements and in which: 
5 FIG. 1 A is a block diagram of a network that illustrates the difference between 

path through a network and a network topology; 

FIG IB is a block diagram that illustrates a loop in a network; 

FIG. IC is a block diagram that illustrates a loop-free path that is created by 
Spanning Tree; 

1 0 FIG. 2 illustrates an overview of a Layer 2 path analysis; 

FIG. 3 illustrates the identification of contiguous pairs of Layer 3 devices in a 
given Layer 3 path; 

FIG. 4 is a flowchart that illustrates a method of determining subpaths; 
FIG. 5 is a flow chart that illustrates the determination of a subpath when both 
1 5 nodes of a contiguous pair have non-trunking ports or interfaces; 

FIG. 6A is a block diagram that illustrates the process of tracing a path segment; 
FIG. 6B is a block diagram that illustrates a loop-free Spanning Tree path for the 
network of FIG. 6 A; 

FIG. 7 is a flow chart that illustrates the determination of a subpath when one of 
20 the nodes of a contiguous pair has a non-trunking port or interface, and the other node has 
a trunking port or interface; 

FIG. 8 is a flow chart that illustrates the determination of a subpath when both 
nodes of a contiguous pair have non-trunking ports or interfaces; 
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FIG. 9 is a block diagram that illustrates a network that is configured in a one-to- 
one mapping between IP subnets and VLANs; and 

FIG. 10 is a block diagram that illustrates a computer system upon which an 
embodiment may be implemented. 
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DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 

A method and apparatus for determining a Layer 2 path between two or more 
nodes in a switched network is disclosed herein. Li the following description, for the 
purposes of explanation, numerous specific details are set forth in order to provide a 
5 thorough understanding of the present invention. It will be apparent, however, to one 
skilled in the art that the present invention may be practiced without these specific details. 
In other instances, well-known structures and devices are shown in block diagram form in 
order to avoid unnecessarily obscuring the present invention. 

OVERVIEW 

1 0 For purposes of illustration, the invention is described in the context of Internet 

Protocol ("IP") network addressing. The IP standard specifies that each host is assigned a 
unique 32-bit number known as the host's IP address, which is used for all 
communication with the host. Each packet sent across an IP network contains the 32-bit 
IP addresses of the sender (source) as well as the intended recipient (destination). 
1 5 The flowchart of FIG. 2 illustrates an overview of a Layer 2 path determination. 

At block 202 a Layer 3 path between a source device and destination device is 
determined. The Layer 3 path determination is described in greater detail below. 

Once a Layer 3 path is determined, all the Layer 3 devices in the Layer 3 path 
between the source and destination device will have been determined. Thus, at block 
20 204, contiguous pairs of Layer 3 devices in the Layer 3 path may be identified. 

At block 206, a subpath is determined for each contiguous pair of Layer 3 devices 
that was determined at block 204. Once the subpaths are determined, the subpaths are 
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concatenated to form a Layer 2 path between the source device and the destination device. 
Subpath determination is described in greater detail below. 

At block 208, the process determines whether any contiguous pair of Layer 3 
devices has no subpath. If one or more contiguous pairs of Layer 3 devices have no 

5 subpath, then at block 210 the process determines that there is no Layer 2 path between 
the source device and destination device. 

However, if block 208 results in determining that each contiguous pair of Layer 3 
devices in the Layer 3 path between the source device and the destination device has a 
subpath, then at block 212, extraneous devices in the subpaths are eliminated, and the 

1 0 subpaths are concatenated to form a Layer 2 path between the source device and the 

destination device as shown by block 213. The process of eliminating extraneous devices 
is further explained herein in the subsection entitled "PATH SEGMENT TRACE". The 
process of determining a Layer 2 path is complete at block 214 of FIG. 2. 

DETERMINATION OF LAYER 3 PATH AND CONTIGUOUS PAIRS 
1 5 The Layer 3 path between a source device and a destination device, as determined 

in block 202 of FIG. 2, can be traced using the "traceroute" computer program or any 
process that is capable of accomplishing the equivalent task. The "traceroute" software 
program is supported by UNIX-based network computers. Windows-based network 
computers support a similar software program called "tracert". Both traceroute and 
20 tracert create and store information defining the path or route comprising specific 

gateway computers or routers at each "hop" through the computer network between a 
source computer and the destination computer, hi a packet-switching network, a hop is 
the next intermediate gateway that a packet visits on its way to its destination. 
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The traceroute program works by sending a packet of data, e.g., using Internet 
Control Message Protocol (ICMP) to the destination end-station. The packet includes a 
time limit value ("time to live") that is selected so as to be exceeded by the first gateway 
that receives the packet, hi turn, the gateway returns a Time Exceeded message. The 
5 traceroute program increases the time limit value and resends the packet so that it will 
reach the next gateway in the path to the packet's destination. 

FIG. 3 illustrates the identification of contiguous pairs of Layer 3 devices in a 
given Layer 3 path, as determined as part of block 204 of FIG. 2. hi FIG. 3, Device 302 
and Device 310 are the source device and destination device respectively. Device 304, 
10 Device 306 and Device 308 are intermediary devices between Device 302 and Device 
310. In particular, Device 306 is a router. 

With respect to FIG. 3, assume that a traceroute or some other process is 
performed to determine the Layer 3 path. Further assume that the Layer 3 path is 
determined to be as follows: 
1 5 Layer 3 Path = Device 302-> Device 306-> Device 3 1 0 

A Layer 3 contiguous pair is hereafter denoted by (node 1, node 2), where node 1 
and node 2 are the two adjacent devices in the Layer 3 path. Thus, the contiguous pairs of 
Layer 3 devices with respect to FIG. 3 are (Device 302, Device 306) and (Device 306, 
Device 310). 

20 DETERMINATION OF SUBPATHS OF CONTIGUOUS PAIRS 

FIG. 4 is a flowchart that illustrates a method of determinmg subpaths of 
contiguous pairs of devices, as carried out as part of block 206 of FIG. 2. FIG. 4 is 
described with reference to FIG. 2 because FIG. 4 describes the details of block 206 of 
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FIG. 2. At block 402 of FIG. 4, determination of the subpath for each contiguous pair of 
Layer 3 devices is started. At block 404, the process determines whether the nodes of a 
continuous pair are such that both nodes have non-trunking ports. Information on the 
nodes may be obtained using Cisco Discovery Protocol. If the process determines that 
both nodes of the contiguous pair have non-trunking ports, then control passes to block 
406, which is further described in greater detail with reference to FIG. 5. 

However, if at block 404 the process determines that the nodes of the contiguous 
pair are not such that both nodes of the contiguous pair have non-trunking ports, then at 
block 408 of FIG. 4, the process determines whether the nodes of the contiguous pair are 
such that one of the nodes of the contiguous pair has a trunking port and the other node of 
the contiguous pair has a non-trunking port. If the process determines that one of the 
nodes of the contiguous pair has a trunking port and the other node of the contiguous pair 
has a non-trunking port, then control passes to block 410, which is further described in 
greater detail with reference to FIG. 7. 

However, if at block 408 the process determines that the nodes of the contiguous 
pair are not such that one of the nodes of the contiguous pair has a trunking port and the 
other node of the contiguous pair has a non-trunking port, then at block 412, the process 
determines whether the nodes of the contiguous pair are such that both nodes of the 
contiguous pair have trunking ports. If the process determines that both nodes of the 
contiguous pair have trunking ports, then control passes to block 414, which is further 
described in greater detail with reference to FIG. 8 below. 
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However, if at block 412 the process determines that the nodes of the contiguous 
pair are not such that both nodes of the contiguous pair have trunking ports, then at block 
416 control returns to block 208 of FIG. 2. 

1 NON-TRIJNKING INTRRFACE TO NON-TRUNKIN G INTERFACE 

5 FIG. 5 is a flow chart that illustrates the determination of a subpath when both 

nodes of a contiguous pair have non-trunking ports or interfaces. At block 502 of FIG. 5, 
the process finds the access port or interface on each node of the contiguous pair for a 
given subnet. At block 504, the process determines the native Virtual Local Area 
Network ("VLAN") of the access port or interface for each node of the contiguous pair. 

1 0 At block 506, the process determines whether the native VLANs that were 

determined at block 504 match. If the process determines that the VLANs do not match, 
then the process of FIG. 5 is complete, and there is no subpath as indicated by block 508. 
However, if the process determines that the VLANs match, then at block 510, the 
matching native VLAN is the relevant VLAN and the process gathers the current 

1 5 Sparming Tree information for the relevant VLAN. 

At block 512, the process traces a path segment along the Spanning Tree from 
each node of the contiguous pair to the root of the Spanning Tree. The process of tracing 
a path segment along the Spanning Tree is described in greater detail with reference to 
FIG. 6A and FIG. 6B below. 

20 At block 5 1 4, the process eliminates extraneous nodes and concatenates the two 

path segments that were traced at block 512 to result in creating and storing the subpath 
for the given contiguous pair. The process of eliminating extraneous nodes and 
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concatenating the path segments is described in greater detail with reference to FIG. 6A 

and FIG. 6B below. 

2. PATH SEGMENT TRACE 

FIG. 6A is a block diagram that illustrates the process of tracing a path segment 
along the Spanning Tree from each node of the contiguous pair to root of the Spanning 
Tree. 

In FIG. 6 A, assume that Device 602 and Device 614 are the nodes of a contiguous 
pair of Layer 3 devices. Further assume that Device 608 is the Root of the Spanning 
Tree. Device 604, Device 606, Device 610, and Device 612 are intermediary devices 
between the source device and the destination device. Device 602 is connected to Device 
604 by Connection 616 and through Access Ports 616a and 616b. Device 604 is 
connected to Device 606 by Connection 618 and through Access Ports 618a and 618b. 
Also, Device 604 is connected to Device 612 by Connection 628 and through Access 
Ports 628a and 628b. 

Device 606 is connected to Device 608 by Connection 620 and through Access 
Ports 620a, 620b. Also, Device 606 is connected to Device 612 by Connection 626 and 
through Access Ports 626a, 626b. Finally, Device 606 is connected to Device 610 by 
Connection 632 and through Access Ports 632a, 632b. 

Device 608 is connected to Device 610 by Connection 622 and through Access 
Ports 622a and 622b. Device 610 is connected to Device 612 by Connection 624 and 
through Access Ports 624a, 624b. Device 614 is connected to Device 612 by Connection 
630 and through Access Ports 630a, 630b. 
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For purposes of illustration, assume that Access Ports 622a, 622b, 628a, 628b, 
624a, and 624b, are placed in a "blocked state" as a result of applying a Spanning Tree 
algorithm to the network of FIG. 6A. Thus, the Spanning Tree is indicated by Connection 
616, 618, 620, 632, 626, 630 as shown in FIG. 6B. 

In this example, the contiguous pair is assumed to be (Device 602, Device 614). 
By the following the Spanning Tree, the process may trace a path segment from Device 
602, which is the first node of the contiguous pair, to the Root of the Spanning Tree, 
which is Device 608. 

Path Segment trace from 

Device 602 to Device 608 = Device 602-> Device 604-> Device 606 

-> Device 608 

Similarly, the process may trace a path segment from Device 614, which is the 
second node of the contiguous pair, to the Root of the Spanning Tree. 
Path Segment trace from Device 614 

to Device 608 = Device 614-> Device 612-> Device 606-> Device 608 

Upon inspection of the above path segment fraces, it can be seen that the trace 
from Device 606->Device 608 is duplicative and thus Device 608 maybe treated as an 
extraneous device in the context of determining subpaths for contiguous pairs. 

The two path segments above maybe concatenated after eliminating exfraneous 
Device 608 to form the subpath for the contiguous pair, (Device 602, Device 614). 

Thus, 

Subpath for (Device 602, Device 614) = Device 602-> Device 604-> Device 606 

-> Device 612-> Device 614 
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3. NQN-TRUNKING INTERFACE TO TRUNKING INTERFACE 

FIG. 7 is a flow chart that illustrates the determination of a subpath when one of 
the nodes of a contiguous pair has a non-trunking port or interface, and the other node has 
5 a trunking port or interface. At block 702, the process determines which node of the 
contiguous pair for a given subnet is non-trunking. At block 704, the process finds the 
access port or interface for the non-trunking node. At block 706, the process determines 
the native VLAN of the access port or interface for the non-trunking node of the 
contiguous pair. 

1 0 At block 708, the process determines whether there is an active VLAN on the 

trunking access port or interface on the trunking node, and which matches the native 
VLAN of the non-trunking node. If the process determines that there in no matching 
VLAN, then the process of FIG. 7 is complete, and there is no subpath as indicated by 
block 710. However, if the process determines that there is an active VLAN on the 

1 5 trunking node that matches the native VLAN of the non-trunking node, then at block 712, 
the matching VLAN is the relevant VLAN and the process gathers the current Spanning 
Tree information for the relevant VLAN. 

At block 714, the process traces a path segment along the Spanning Tree from 
each node of the contiguous pair to the root of the Spanning Tree. The process of tracing 

20 a path segment along the Spanning Tree is previously described above with reference to 
FIG. 6A and FIG. 6B. 

At block 716, the process eliminates extraneous nodes and concatenates the two 
path segments that were traced at block 714 to result in creating and storing the subpath 
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for the given contiguous pair. The process of eliminating extraneous nodes and 
concatenating the path segments has been described with reference to FIG. 6A and FIG. 
6B. 

5 4. TRUNKING INTERFACE TO TRUNKING INTERFACE 

FIG. 8 is a flow chart that illustrates the determination of a subpath when both 
nodes of a contiguous pair have non-trunking ports or interfaces. At block 802, for each 
node of the contiguous pair, the process selects the active VLAN associated with the IP 
subnet to which the contiguous pair belongs. At block 804, the process determines 

1 0 whether the active VLANs that are selected at block 802 match. 

If the process determines that the active VLANs do not match, then the process of 
FIG. 8 is complete, and there is no subpath as indicated by block 806. However, if the 
process determines that the active VLANs match, then at block 808, the matching VLAN 
is the relevant VLAN, and the process gathers the current Spanning Tree information for 

1 5 the relevant VLAN. 

At block 810, the process traces a path segment along the Spanning Tree from 
each node of the contiguous pair to the root of the Spanning Tree. The process of tracing 
a path segment along the Spanning Tree is previously described above with reference to 
FIG. 6A and FIG. 6B. 

20 At block 8 1 2, the process eliminates extraneous nodes and concatenates the two 

path segments that were traced at block 810 to form the subpath for the given contiguous 
pair. The process of eliminating extraneous nodes and concatenating the path segments is 
previously described above with reference to FIG. 6A and FIG. 6B. 
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LAYER 2 PATH 

Once the subpaths are determined, extraneous nodes are eliminated and the 
subpaths are concatenated to form a Layer 2 path between a source device and a 
5 destination device. Two examples of a Layer 2 path analysis embodying some of the 
processes previously described above will be illustrated with reference to FIG. 9. FIG. 9 
is a block diagram that illustrates a network that is configured in a one-to-one mapping 
between IP subnets and VLANs. 

hi FIG. 9, for purposes of illustration assume that Devices 902, 912 are source 
10 devices and Devices 904, 914 are destination devices. Further assume that the TP 
addresses of the devices are as follows: 

IP address of Device 902 = 172.16.1.2 
IP address of Device 904 = 172.16.2.3 
IP address of Device 912 = 172.16.1.3 
15 IP address of Device 914 = 172.16.2.2 

Thus, Device 902 and Device 912 belong to the same subnet, namely, the 
172.16.1 subnet. Similarly, Device 904 and Device 914 belong to the 172.16.2 subnet. 
Also, assume that the network of FIG. 9 is configured with two VLANs named VLAN 
20 RED and VLAN BLUE. Further assume that VLAN RED is mapped to the 1 72. 1 6. 1 
subnet and VLAN Blue is mapped to the 172.16.2 subnet. 

Switch 906 is the root of VLAN RED and Switch 910 is the root of VLAN BLUE. 
Assume that Switches 906 and 910 have trunking access ports or interfaces. In particular, 
Switches 906 and 910 are capable of trunking between VLAN RED and VLAN BLUE. 
25 Router 908 routes packets between VLAN RED and VLAN BLUE. 
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The Layer 2 path analysis for a packet emanating from Device 902 and destined 



for Device 914 is as follows: 

Layer 3 path between Device 902 and Device 914 = Device 902 -> Router 908 

-> Device 914 

Contiguous pairs are: (Device 902, Router 908) and (Router 908, Device 914) 
Active VLAN associated with IP subnet of (Device 902, Router 908) is: VLAN 

RED 

Path Segment trace along Spanning tree from node Device 902 to Root of VLAN 
RED is: Device 902->Switch 906 

Path Segment trace along Spanning free from node Router 908 to Root of VLAN 
RED is: Router 908->Switch 906 

Thus, subpath of (Device 902, Router 908) is: Device 902-> Switch 906 

-> Router 908 

Active VLAN associated with IP subnet of (Router 908, Device 914) is: VLAN 

BLUE 

Path Segment frace along Spanning free from node Router 908 to Root of VLAN 
BLUE is: Router 908 ->Switch 910 

Path Segment frace along Spanning free from node Device 914 to Root of VLAN 
BLUE is: Device 914-> Switch 910 

Thus, subpath of (Router 908, Device 914) is: Router 908 -> Switch 910 

-> Device 914 

Thus, Layer 2 path between Device 902 to Device 914 is: 

subpath of (Device 902, Router 908) + subpath of (Router 908, Device 914) 
= Device 902-> Switch 906-> Router 908 -> Switch 910-> Device 914 



The Layer 2 path analysis for a packet emanating from Device 902 and destined 
for Device 904 is as follows: 

Layer 3 path between Device 902 and Device 904 = Device 902 -> Router 908 

-> Device 904 

Contiguous pairs are: (Device 902, Router 908) and (Router 908, Device 904) 
Active VLAN associated with IP subnet of (Device 902, Router 908) is: VLAN 

RED 

Path Segment frace along Spanning free from node Device 902 to Root of VLAN 
RED is: Device 902->Switch 906 

Path Segment frace along Spanning free from node Router 908 to Root of VLAN 
RED is: Router 908->Switch 906 

Thus, subpath of (Device 902, Router 908) is: Device 902-> Switch 906 

-> Router 908 
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Active VLAN associated with IP subnet of (Router 908, Device 904) is: VLAN 

BLUE 

Path Segment trace along Spanning tree from node Router 908 to Root of VLAN 
BLUE is: Router 908 -> Switch 910 

Path Segment trace along Spanning tree from node Device 904 to Root of VLAN 

BLUE is: Device 904->Switch 906 ->(trunking)-> Switch 910 

Thus, subpath of (Router 908, Device 914) is: Router 908 -> Switch 910 

-> Switch 906 -> Device 904 

Thus, Layer 2 path between Device 902 to Device 904 is: 

subpath of (Device 902, Router 908) + subpath of (Router 908, Device 904) 
= Device 902-> Switch 906-> Router 908 -> Switch 910-> Switch 906 
->Device 904 



HARDWARE OVERVIEW 

FIG. 10 is a block diagram that illustrates a computer system 1000 upon which an 
embodiment of the invention may be implemented. Computer system 1000 includes a 
bus 1002 or other communication process for communicating information, and a 
processor 1004 coupled with bus 1002 for processing information. Computer system 
1000 also includes a main memory 1006, such as a random access memory (RAM) or 
other dynamic storage device, coupled to bus 1002 for storing information and 
instructions to be executed by processor 1004. Main memory 1006 also may be used for 
storing temporary variables or other intermediate information during execution of 
instructions to be executed by processor 1004. Computer system 1000 further includes a 
read only memory (ROM) 1008 or other static storage device coupled to bus 1002 for 
storing static information and instructions for processor 1004. A storage device 1010, 
such as a magnetic disk or optical disk, is provided and coupled to bus 1002 for storing 
information and instructions. 
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Computer system 1000 maybe coupled via bus 1002 to a display 1012, such as a 
cathode ray tube (CRT), for displaying inforaiation to a computer user. An input device 
1014, including alphanumeric and other keys, is coupled to bus 1002 for conmiunicating 
information and command selections to processor 1004. Another type of user input 

5 device is cursor control 1016, such as a mouse, a trackball, or cursor direction keys for 
communicating direction information and command selections to processor 1004 and for 
controlling cursor movement on display 1012. This input device typically has two 
degrees of freedom in two axes, a first axis (e.g., x) and a second axis (e.g., y), that allows 
the device to specify positions in a plane. 

1 0 The invention is related to the use of computer system 1 000 for analyzing a Layer 

2 path in a switched network. According to one embodiment of the invention, analyzing 
a Layer 2 path in a switched network is provided by computer system 1 000 in response to 
processor 1004 executing one or more sequences of one or more instructions contained in 
main memory 1 006. Such instructions may be read into main memory 1 006 from another 

15 computer-readable medium, such as storage device 1010. Execution of the sequences of 
instructions contained in main memory 1006 causes processor 1004 to perform the 
process steps described herein. In alternative embodiments, hard-wired circuitry may be 
used in place of or in combination with software instructions to implement the invention. 
Thus, embodiments of the invention are not limited to any specific combination of 

20 hardware circuitry and software. 

The term "computer-readable medium" as used herein refers to any medium that 
participates in providing instructions to processor 1004 for execution. Such a medium 
may take many forms, including but not limited to, non- volatile media, volatile media, 
and tiansmission media. Non-volatile media includes, for example, optical or magnetic 

25 disks, such as storage device 1010. Volatile media includes dynamic memory, such as 
main memory 1006. Transmission media includes coaxial cables, copper wire and fiber 
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optics, including the wires that comprise bus 1002. Transmission media can also take the 
form of acoustic or light waves, such as those generated during radio- wave and infra-red 
data communications. 

Common forms of computer-readable media include, for exmiple, a floppy disk, a 
5 flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any 
other optical medium, punchcards, papertape, any other physical medium with patterns of 
holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, any other memory chip or 
cartridge, a carrier wave as described hereinafter, or any other medium from which a 
computer can read. 

1 0 Various forms of computer readable media may be involved in carrying one or 

more sequences of one or more instructions to processor 1004 for execution. For 
example, the instructions may initially be carried on a magnetic disk of a remote 
computer. The remote computer can load the instructions into its dynamic memory and 
send the instructions over a telephone line using a modem. A modem local to computer 

1 5 system 1 000 can receive the data on the telephone line and use an infra-red transmitter to 
convert the data to an infra-red signal. An infra-red detector can receive the data carried 
in the infra-red signal and appropriate circuitry can place the data on bus 1 002. Bus 1 002 
carries the data to main memory 1006, from which processor 1004 retrieves and executes 
the instructions. The instructions received by main memory 1 006 may optionally be 

20 stored on storage device 1010 either before or after execution by processor 1004. 

Computer system 1000 also includes a communication interface 1018 coupled to 
bus 1002. Communication interface 1018 provides a two-way data communication 
coupling to a network link 1020 that is connected to a local network 1022. For example, 
communication interface 1018 maybe an integrated services digital network (ISDN) card 

25 or a modem to provide a data communication connection to a corresponding type of 
telephone line. As another example, communication interface 1018 maybe a local area 
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network (LAN) card to provide a data communication connection to a compatible LAN. 
Wireless links may also be implemented. In any such implementation, communication 
interface 1018 sends and receives electrical, electromagnetic or optical signals that carry 
digital data streams representing various types of information. 
5 Network link 1 020 typically provides data communication through one or more 

networks to other data devices. For example, network link 1020 may provide a 
connection through local network 1022 to a host computer 1024 or to data equipment 
operated by an Internet Service Provider (ISP) 1026. ISP 1026 in turn provides data 
communication services through the world wide packet data communication network now 

10 commonly referred to as the "Internet" 1028. Local network 1022 and Internet 1028 both 
use electrical, electromagnetic or optical signals that carry digital data streams. The 
signals through the various networks and the signals on network link 1020 and through 
conununication interface 1018, which carry the digital data to and from computer system 
1 000, are exemplary forms of carrier waves transporting the information. 

1 5 Computer system 1 000 can send messages and receive data, including program 

code, through the network(s), network link 1020 and communication interface 1018. In 
the Internet example, a server 1030 might transmit a requested code for an application 
program through Internet 1028, ISP 1026, local network 1022 and communication 
interface 1018. In accordance with the invention, one such downloaded application 

20 provides for analyzing a Layer 2 path in a switched network as described herein. 

The received code maybe executed by processor 1004 as it is received, and/or 
stored in storage device 1010, or other non-volatile storage for later execution. In this 
manner, computer system 1000 may obtain application code in the form of a carrier wave. 
In the foregoing specification, the invention has been described with reference to 

25 specific embodiments thereof. It will, however, be evident that various modifications and 
changes may be made thereto without departing from the broader spirit and scope of the 
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invention. The specification and drawings are, accordingly, to be regarded in an 
illustrative rather than a restrictive sense. 
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CLAIMS 

What is claimed is: 



1 1 / A method of determining a Layer 2 path between a source device and a 

2 / destination device in a switched network, the method comprising the computer- 

3 implemented steps of: 

4 determining a Layer 3 path between the source device and the destination device, 

5 wherein the Layer 3 path comprises information identifying two or more 

6 Layer 3 devices; 

7 determining a subpath for each contiguous pair of Layer 3 devices in the Layer 3 

8 path; and 

9 concatenating the subpaths to result in creating and storing information 
1 0 representing the Layer 2 path. 

1 2. The method as recited in Claim 1 , wherein determining a subpath for each 

2 contiguous pair of Layer 3 devices comprises the steps of: 

3 determining a first interface on a first node of the contiguous pair that is connected 

4 to a second interface on a second node of the contiguous pair for a given 

5 subnet; and 

6 selecting a relevant VLAN between the first and second nodes of the contiguous 

7 pair based on the first and second interfaces; and 

8 gathering current spanning tree information for the relevant VLAN. 
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13. The method as recited in Claim 2, wherein selecting a relevant VLAN between the 

2 first and second nodes of the contiguous pair comprises the steps of: 

3 selecting a matching native VLAN of the first and second node of the contiguous 

4 pair as the relevant VLAN when the first interface and the second interface 

5 of the first and second nodes respectively of the contiguous pair are non- 

6 VLAN trunking interfaces; 

7 selecting a matching active VLAN that is designated to carry traffic to a next hop 

8 as the relevant VLAN when the first interface and the second interface of 

9 the first and second nodes respectively of the contiguous pair are VLAN 

10 trunking interfaces; and 

1 1 selecting a native VLAN that is on a non-VLAN trunking interface as the relevant 

1 2 VLAN when one of the nodes of the contiguous pair has the non-VLAN 

13 trunking interface. 

1 4. The method as recited in Claim 1 , wherein determining a subpath for each 

2 contiguous pair of Layer 3 devices further comprises the steps of: 

3 tracing a first path segment from a first node of the contiguous pair by following a 

4 spanning tiree associated with a relevant VLAN for the contiguous pair to a 

5 root of the spanning tree; 

6 tracing a second path segment from a second node of the contiguous pair by 

7 following the spanning ti-ee associated with the relevant VLAN for the 

8 contiguous pair to the root of the spanning tree; and 
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9 concatenating the &st second path segments to result in creating and storing the 

1 0 subpath for the contiguous pair. 

15. The method as recited in Claim 4, wherein concatenating the first path segment 

2 and the second path segment to result in creating and storing the subpath for the 

3 contiguous pair includes the step of eliminating extraneous devices firom the first 

4 and second path segments. 

1 6. The method as recited in Claim 1 , wherein concatenating the subpaths to result in 

2 creating and storing information representing the Layer 2 path includes the step of 

3 eliminating extraneous devices firom the subpaths. 



A method of determining a Layer 2 path between a source device and a 
destination device in a switched network, the method comprising the computer- 
implemented steps of: 

determining a Layer 3 path between the source device and the destination device, 
wherein the Layer 3 path comprises information identifying two or more 
Layer 3 devices; 

identifying contiguous pairs of Layer 3 devices in the Layer 3 path; 
determining a subpath for each contiguous pair of Layer 3 devices in the Layer 3 
path; 

determining whether any contiguous pair of Layer 3 devices has no subpath; 




2 
3 
4 
5 
6 
7 
8 
9 
10 
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1 1 concluding that there is no Layer 2 path when any contiguous pair of Layer 3 

12 devices has no subpath; 

13 eliminating extraneous devices in the subpaths; and 

14 concatenating the subpaths to result in creating and storing information 

1 5 representing the Layer 2 path when each of the contiguous pairs of Layer 3 

1 6 devices has a subpath. 

1 8. The method as recited in Claim 7, wherein determining a subpath for each 

2 contiguous pair of Layer 3 devices comprises the steps of: 

3 determining a first interface on a first node of the contiguous pair that is connected 

4 to a second interface on a second node of the contiguous pair for a given 

5 subnet when both the first node of the contiguous pair and the second node 

6 of the contiguous pair have non-trunking interfaces; 

7 determining a first native VLAN of the first interface and a second native VLAN 

8 the second interface; 

9 determining whether the first native VLAN matches the second native VLAN; 

1 0 selecting the matching VLAN as a relevant VLAN between the first and second 

1 1 nodes of the contiguous pair when the first native VLAN matches the 

1 2 second native VLAN; 

1 3 gathering a current spanning tree information for the relevant VLAN; 

14 tracing a first path segment fi-om the first node of the contiguous pair to a root of 

1 5 the spanning tree by following the current spanning tree information 

1 6 associated with the relevant VLAN to a root of the spanning tree; 
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1 7 tracing a second path segment from the second node of the contiguous pair to the 

1 8 root of the spanning tree by following the current spanning tree 

1 9 information associated with the relevant VLAN; 

20 eliminating extraneous devices in the first and second path segments; and 

21 concatenating the first path segment and the second path segment to result in 

22 creating and storing the subpath for the contiguous pair. 

1 9. The method as recited in Claim 7, wherein determining a subpath for each 

2 contiguous pair of Layer 3 devices comprises the steps of: 

3 determining a non-trunking node of the contiguous pair when one of the nodes of 

4 the contiguous pair for a given subnet has a non-trunking interface and the 

5 other node of the contiguous pair has a trunking interface; 

6 determining the non-trunking interface on the non-trunking node of the contiguous 

7 pair as a first interface that is connected to a second interface on the other 

8 node of the contiguous pair; 

9 determining a native VLAN on the first interface; 

1 0 determining whether there is an active VLAN on the second interface that matches 

1 1 the native VLAN on the first interface; 

1 2 selecting the matching VLAN as a relevant VLAN between the non-trunking node 

1 3 and the other node of the contiguous pair when there is an active VLAN on 

14 the second interface that matches the native VLAN on the first interface; 

1 5 gathering a current spanning tree information for the relevant VLAN; 



50325-0107 (Seq. No 1754) 



-34- 



1 6 tracing a first patK segment from the non-trunking node of the contiguous pair to a 

17 root of the spanning tree by following the current spanning tree 

18 information associated with the relevant VLAN to a root of the spanning 

19 tree; 

20 tracing a second path segment from the other node of the contiguous pair to the 

21 root of the spanning tree by following the current spanning tree 

22 information associated with the relevant VLAN; 

23 eliminating extraneous devices in the first and second path segments; and 

24 concatenating the first path segment and the second path segment to result in 

25 creating and storing the subpath for the contiguous pair. 

1 10. The method as recited in Claim 7, wherein determining a subpath for each 

2 contiguous pair of Layer 3 devices comprises the steps of: 

3 determining a first interface on a first node of the contiguous pair that is connected 

4 to a second interface on a second node of the contiguous pair for a given 

5 subnet when both the first node of the contiguous pair and the second node 

6 of the contiguous pair have non-trunking interfaces; and 

7 determining a first active VLAN of the first interface associated with the given 

8 subnet and a second active VLAN the second interface associated with the 

9 given subnet; 

1 0 determining whether the first active VLAN matches the second active VLAN; 
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1 1 selecting the matching VLAN as a relevant VLAN between the first and second 

12 nodes of the contiguous pair when the first active VLAN matches the 

1 3 second active VLAN; 

14 gathering a current spanning tree information for the relevant VLAN; 

1 5 tracing a first path segment from the first node of the contiguous pair to a root of 

16 the spanning tree by following the current spanning tree information 

17 associated with the relevant VLAN to a root of the spanning tree; 

1 8 tracing a second path segment fi:*om the second node of the contiguous pair to the 

1 9 root of the spanning tree by following the current spanning tree 

20 information associated with the relevant VLAN; 

21 eliminating extraneous devices in the first and second path segments; and 

22 concatenating the first path segment and the second path segment to result in 

23 creating and storing the subpath for the contiguous pair. 

1 ^^/L A computer-readable medium carrying one or more sequences of one or more 

2 instructions for determining a Layer 2 path between a source node and a 

3 destination node in a switched network, the one or more sequences of one or more 

4 instructions including instructions which, when executed by one or more 

5 processors, cause the one or more processors to perform the steps of: 

6 determining a Layer 3 path between the source device and the destination device, 

7 wherein the Layer 3 path comprises information identifying two or more 

8 Layer 3 devices; 
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9 determining a subpath for each contiguous pair of Layer 3 devices in the Layer 3 
1 0 path; and 

] 1 concatenating the subpaths to result in creating and storing information 
12 representing the Layer 2 path. 

1 12. The computer-readable medium as recited in Claim 1 1 , wherein determining a 

2 subpath for each contiguous pair of Layer 3 devices comprises the steps of: 

3 determining a first interface on a first node of the contiguous pair that is connected 

4 to a second interface on a second node of the contiguous pair for a given 

5 subnet; and 

6 selecting a relevant VLAN between the first and second nodes of the contiguous 

7 pair based on the first and second interfaces; and 

8 gathering current spanning tree information for the relevant VLAN, 

1 13. The computer-readable medium as recited in Claim 1 2, wherein selecting a 

2 relevant VLAN between the first and second nodes of the contiguous pair 

3 comprises the steps of: 

4 selecting a matching native VLAN of the first and second node of the contiguous 

5 pair as the relevant VLAN when the first interface and the second interface 

6 of the first and second nodes respectively of the contiguous pair are non- 

7 VLAN trunking interfaces; 

8 selecting a matching active VLAN that is designated to carry traffic to a next hop 

9 as the relevant VLAN when the first interface and the second interface of 
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10 the first and second nodes respectively of the contiguous pair are VLAN 

1 1 trunking interfaces; and 

12 selecting a native VLAN that is on a non-VLAN trunking interface as the relevant 

1 3 VLAN when one of the nodes of the contiguous pair has the non-VLAN 

1 4 trunking interface. 

1 14. The computer-readable medium as recited in Claim 1 1, wherein determining a 

2 subpath for each contiguous pair of Layer 3 devices further comprises the steps of: 

3 tracing a first path segment from a first node of the contiguous pair by following a 

4 spanning tree associated with a relevant VLAN for the contiguous pair to a 

5 root of the spanning tree; 

6 tracing a second path segment from a second node of the contiguous pair by 

7 following the spanning tree associated with the relevant VLAN for the 

8 contiguous pair to the root of the spanning tree; and 

9 concatenating the first second path segments to result in creating and storing the 
1 0 subpath for the contiguous pair. 

1 15. The computer-readable medium as recited in Claim 1 4, wherein concatenating the 

2 first path segment and the second path segment to result in creating and storing the 

3 subpath for the contiguous pair includes the step of eliminating extraneous devices 

4 from the first and second path segments. 
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1 1 6. The computer-readable medium as recited in Claim 1 1 , wherein concatenating the 

2 subpaths to result in creating and storing information representing the Layer 2 path 

3 includes the step of eliminating extraneous devices from the subpaths. 

/ 

1 /1 7. A computer-readable medium carrying one or more sequences of one or more 

2 instructions for determining a Layer 2 path between a source node and a 

3 destination node in a switched network, the one or more sequences of one or more 

4 instructions including instructions which, when executed by one or more 

5 processors, cause the one or more processors to perform the steps of: 

6 determining a Layer 3 path between the source device and the destination device, 

7 wherein the Layer 3 path comprises information identifying two or more 

8 Layer 3 devices; 

9 identifying contiguous pairs of Layer 3 devices in the Layer 3 path; 

10 determining a subpath for each contiguous pair of Layer 3 devices in the Layer 3 

1 1 path; 

12 determining whether any contiguous pair of Layer 3 devices has no subpath; 

13 concluding that there is no Layer 2 path when any contiguous pair of Layer 3 

14 devices has no subpath; 

15 eliminating extraneous devices in the subpaths; and 

16 concatenating the subpaths to result in creating and storing information 

1 7 representing the Layer 2 path when each of the contiguous pairs of Layer 3 

1 8 devices has a subpath. 
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1 18. The computer-readable medium as recited in Claim 1 7, wherein determining a 

2 subpath for each contiguous pair of Layer 3 devices comprises the steps of: 

3 determining a first interface on a first node of the contiguous pair that is connected 

4 to a second interface on a second node of the contiguous pair for a given 

5 subnet when both the first node of the contiguous pair and the second node 

6 of the contiguous pair have non-trunking interfaces; 

7 determining a first native VLAN of the first interface and a second native VLAN 

8 the second interface; 

9 determining whether the first native VLAN matches the second native VLAN; 

10 selecting the matching VLAN as a relevant VLAN between the first and second 

1 1 nodes of the contiguous pair when the first native VLAN matches the 

1 2 second native VLAN; 

1 3 gathering a current spanning tree information for the relevant VLAN; 

14 tracing a first path segment from the first node of the contiguous pair to a root of 

1 5 the spanning tree by following the current spanning tree information 

1 6 associated with the relevant VLAN to a root of the spanning tree; 

17 tracing a second path segment fi-om the second node of the contiguous pair to the 

1 8 root of the spanning tree by following the current spanning tree 

1 9 information associated with the relevant VLAN; 

20 eliminating extraneous devices in the first and second path segments; and 

2 1 concatenating the first path segment and the second path segment to result in 

22 creating and storing the subpath for the contiguous pair. 
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1 19. The computer-readable medium as recited in Claim 1 1, wherein determining a 

2 subpath for each contiguous pair of Layer 3 devices comprises the steps of: 

3 determining a non-trunking node of the contiguous pair when one of the nodes of 

4 the contiguous pair for a given subnet has a non-trunking interface and the 

5 other node of the contiguous pair has a trunking interface; 

6 determining the non-trunking interface on the non-trunking node of the contiguous 

7 pair as a first interface that is connected to a second interface on the other 

8 node of the contiguous pair; 

9 determining a native VLAN on the first interface; 

1 0 determining whether there is an active VLAN on the second interface that matches 

1 1 the native VLAN on the first interface; 

12 selecting the matching VLAN as a relevant VLAN between the non-trunking node 

1 3 and the other node of the contiguous pair when there is an active VLAN on 

14 the second interface that matches the native VLAN on the first interface; 

1 5 gathering a current spanning tree information for the relevant VLAN; 

16 tracing a first path segment fi^om the non-trunking node of the contiguous pair to a 

1 7 root of the spanning tree by following the current spanning tree 

1 8 information associated with the relevant VLAN to a root of the spanning 

19 tree; 

20 tracing a second path segment fi*om the other node of the contiguous pair to the 

2 1 root of the spanning tree by following the current spanning tree 

22 information associated with the relevant VLAN; 
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23 eliminating extraneous devices in the first and second path segments; and 

24 concatenating the first path segment and the second path segment to result in 

25 creating and storing the subpath for the contiguous pair. 

1 20. The computer-readable medium as recited in Claim 1 7, wherein determining a 

2 subpath for each contiguous pair of Layer 3 devices comprises the steps of: 

3 determining a first interface on a first node of the contiguous pair that is connected 

4 to a second interface on a second node of the contiguous pair for a given 

5 subnet when both the first node of the contiguous pair and the second node 

6 of the contiguous pair have non-trunking interfaces; and 

7 determining a first active VLAN of the first interface associated with the given 

8 subnet and a second active VLAN the second interface associated with the 

9 given subnet; 

1 0 determining whether the first active VLAN matches the second active VLAN; 

1 1 selecting the matching VLAN as a relevant VLAN between the first and second 

1 2 nodes of the contiguous pair when the first active VLAN matches the 

1 3 second active VLAN; 

14 gathering a current spanning tree information for the relevant VLAN; 

1 5 tracing a first path segment firom the first node of the contiguous pair to a root of 

1 6 the spanning tree by following the current spanning tree information 

1 7 associated with the relevant VLAN to a root of the spaiming tree; 
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1 8 tracing a second path segment from the second node of the contiguous pair to the 

] 9 root of the spanning tree by following the current spanning tree 

20 information associated with the relevant VLAN; 

21 eliminating extraneous devices in the first and second path segments; and 

22 concatenating the first path segment and the second path segment to result in 

23 creating and storing the subpath for the contiguous pair. 

1 A computer data signal embodied in a carrier wave, the computer data signal 

2 carrying one or more sequences of instructions for determining a Layer 2 path 

3 between a source node and a destination node in a switched network, wherein 

4 execution of the one or more sequences of instructions by one or more processors 

5 causes the one or more processors to perform the steps of: 

6 determining a Layer 3 path between the source device and the destination device, 

7 wherein the Layer 3 path comprises information identifying two or more 

8 Layer 3 devices; 

9 determining a subpath for each contiguous pair of Layer 3 devices in the Layer 3 

10 path; and 

1 1 concatenating the subpaths to result in creating and storing information 

1 2 representing the Layer 2 path. 

1 2^, A computer apparatus comprising: 

2 ^ a processor; and 

3 a memory coupled to the processor, the memory containing one or more sequences 

4 of instructions for determining a Layer 2 path between a source node and a 

5 destination node in a switched network, wherein execution of the one or 

-43- 



50325-0107 (Seq. No 1754) 



6 more sequences of instructions by the processor causes the processor to 

7 perform the steps of: 

8 determining a Layer 3 path between the source device and the destination device, 

9 wherein the Layer 3 path comprises information identifying two or more 

10 Layer 3 devices; 

1 1 determining a subpath for each contiguous pair of Layer 3 devices in the Layer 3 

12 path; and 

13 concatenating the subpaths to result in creating and storing information 

1 4 representing the Layer 2 path. 

1 ^^/^ ^ computer data signal embodied in a carrier wave, the computer data signal 

2 carrying one or more sequences of instructions for determining a Layer 2 path 

3 between a source node and a destination node in a switched network, wherein 

4 execution of the one or more sequences of instructions by one or more processors 

5 causes the one or more processors to perform the steps of: 

6 determining a Layer 3 path between the source device and the destination device, 

7 wherein the Layer 3 path comprises information identifying two or more 

8 Layer 3 devices; 

9 identifying contiguous pairs of Layer 3 devices in the Layer 3 path; 

1 0 determining a subpath for each contiguous pair of Layer 3 devices in the Layer 3 

11 path; 

12 determining whether any contiguous pair of Layer 3 devices has no subpath; 

1 3 concluding that there is no Layer 2 path when any contiguous pair of Layer 3 

14 devices has no subpath; 
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1 5 eliminating extraneous devices in the subpaths; and 

16 concatenating the subpaths to result in creating and storing information 

1 7 representing the Layer 2 path when each of the contiguous pairs of Layer 3 

1 8 devices has a subpath. 

/ 

1 24. A network device that can determine a Layer 2 path between a source node and a 

2 destination node in a switched network comprising: 

3 a network interface; 

4 a processor coupled to the network interface and receiving information from the 

5 network interface; and 

6 a computer-readable medium accessible by the processor and comprising one or 

7 more sequences of instructions which, when executed by the processor, 

8 cause the processor to carry out the steps of: 

9 determining a Layer 3 path between the source device and the destination 

1 0 device, wherein the Layer 3 path comprises information identifying 

1 1 two or more Layer 3 devices; 

12 identifying contiguous pairs of Layer 3 devices in the Layer 3 path; 

1 3 determining a subpath for each contiguous pair of Layer 3 devices in the 

14 Layer 3 path; 

1 5 determining whether any contiguous pair of Layer 3 devices has no 

16 subpath; 

17 concluding that there is no Layer 2 path when any contiguous pair of Layer 

18 3 devices has no subpath; 

19 eliminating extraneous devices in the subpaths; and 
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20 concatenating the subpaths to result in creating and storing information 

21 representing the Layer 2 path when each of the contiguous pairs of 

22 Layer 3 devices has a subpath. 

1 A system for determining a Layer 2 path between a source node and a destination 

2 ^ node in a switched network, the system comprising: 

3 means for determining a Layer 3 path between the source device and the 

4 destination device, wherein the Layer 3 path comprises information 

5 identifying two or more Layer 3 devices; 

6 means for identifying contiguous pairs of Layer 3 devices in the Layer 3 path; 

7 means for determining a subpath for each contiguous pair of Layer 3 devices in the 

8 Layer 3 path; 

9 means for determining whether any contiguous pair of Layer 3 devices has no 

10 subpath; 

1 1 means for concluding that there is no Layer 2 path when any contiguous pair of 

12 Layer 3 devices has no subpath; 

13 means for eliminating extraneous devices in the subpaths; and 

14 means for concatenating the subpaths to result in creating and storing information 

15 representing the Layer 2 path when each of the contiguous pairs of Layer 3 

16 devices has a subpath. 
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ABSTRACT OF THE DISCLOSURE 
A metiiod and apparatus that provide for a Layer 2 path determination are disclosed. In 
one embodiment of the invention, a Layer 3 path between a source device and destination 
device is first determined in order to identify contiguous pairs of Layer 3 devices. A 
subpath is then determined for each contiguous pair of Layer 3 devices based on VLAN 
and spanning tree information associated with the contiguous pair. The Layer 2 path is a 
concatenation of the subpaths of all the contiguous pairs in the Layer 3 path. 
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